

1. A memory controller, comprising:

- a plurality of data pads and strobe pads, wherein data is read and written at each of said data pads in sync with a strobe that is received at or generated by a corresponding one of said strobe pads;
- for each data pad, receiver circuitry comprising P storage elements, wherein i) in a first mode, data bits stored by the P storage elements are multiplexed to generate a single data stream, and ii) in a second mode, data bits stored in the P storage elements are multiplexed to generate at least two data streams; and
- for each strobe pad, receiver circuitry comprising a counter to count received strobe edges; wherein particular counts of strobe edges received at a particular strobe pad cause data to be received by particular ones of the P storage elements associated with data pads corresponding to the particular strobe pad.

2. The memory controller of claim 1, wherein each of said storage elements is a latch.

3. The memory controller of claim 1, wherein each of said storage elements is a flip-flop.

4. The memory controller of claim 1, wherein each of said counters is a rollover counter which produces said count as a P bit, one-high count.

5. The memory controller of claim 1, wherein P=4.

6. The memory controller of claim 1, wherein the at least two data streams consist of even and odd data streams.

7. The memory controller of claim 1, further comprising:  
a clock generation circuit to generate strobes at said strobe

pads at a 1x rate when the memory controller is configured in said first mode, or at an Mx rate when the memory controller is configured in said second mode;

for each data pad, driver circuitry to alternately couple ones of a corresponding subset of N data propagation circuits to the data pad, thereby driving a merged data stream to the data pad; and

circuitry to, i) in said first mode, provide like data input streams to each of the N data propagation circuits associated with a given data pad, and ii) in said second mode, provide different data input streams to each of the N data propagation circuits associated with a given data pad.

8

12.

The memory controller of claim 11, wherein for each data pad, said driver circuitry comprises N sequentially clocked flip-flops which respectively receive and output data from the N data propagation circuits.

9

16.

The memory controller of claim 11, wherein for each data pad, said driver circuitry comprises a multiplexer which receives and sequentially outputs data from the N data propagation circuits.

10

14.

The memory controller of claim 11, wherein for each data pad, said driver circuitry comprises N tri-statable paths which respectively receive and sequentially output data from the N data propagation circuits.

11

15.

The memory controller of claim 8, further comprising a memory to store indications of data/strobe ratios that are required to access memory devices that are coupled to said data and strobe pads of the memory controller; wherein, for a data transmission initiated with a particular one of the memory devices, a number of said data pads is dynamically associated with a number of said strobe pads, in

response to a corresponding indication of a data/strobe ratio stored in the memory.

*12*

*16.* A computer system, comprising:

a CPU;

a memory controller coupled to said CPU; and

a number of memory devices coupled to said memory controller;

wherein said memory controller comprises:

a plurality of data pads and strobe pads coupled to said memory devices, wherein data is read and written at each of said data pads in sync with a strobe that is received at or generated by a corresponding one of said strobe pads;

for each data pad, receiver circuitry comprising P storage elements, wherein i) in a first mode, data bits stored by the P storage elements are multiplexed to generate a single data stream, and ii) in a second mode, data bits stored in the P storage elements are multiplexed to generate at least two data streams; and

for each strobe pad, receiver circuitry comprising a counter to count received strobe edges; wherein particular counts of strobe edges received at a particular strobe pad cause data to be received by particular ones of the P storage elements associated with data pads corresponding to the particular strobe pad.

*13*

*17.*

The computer system of claim *16*, wherein each of said counters is a rollover counter which produces said count as a P bit, one-high count.

*14*

*18.*

The computer system of claim *16*, further comprising:

a clock generation circuit to generate strobes at said strobe pads at a 1x rate when the memory controller is configured in said first mode, or at an Mx rate when the memory controller is configured in said second mode;

for each data pad, driver circuitry to alternately couple ones of a corresponding subset of N data propagation circuits to the data pad, thereby driving a merged data stream to the data pad; and  
circuitry to, i) in said first mode, provide like data input streams to each of the N data propagation circuits associated with a given data pad, and ii) in said second mode, provide different data input streams to each of the N data propagation circuits associated with a given data pad.

15

16

The computer system of claim 16, further comprising a memory to store indications of data/strobe ratios that are required to access memory devices that are coupled to said data and strobe pads of the memory controller; wherein, for a data transmission initiated with a particular one of the memory devices, a number of said data pads is dynamically associated with a number of said strobe pads, in response to a corresponding indication of a data/strobe ratio stored in the memory.

12